package org.argus.job.common.model;

import java.util.List;

import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import org.argus.common.core.domain.BaseDO;
import org.argus.common.core.enums.StatusEnum;
import org.argus.common.core.json.LongListSerializer;
import org.argus.job.common.enums.DispatchStrategy;
import org.argus.job.common.enums.ExecuteType;
import org.argus.job.common.enums.ProcessorType;
import org.argus.job.common.enums.TimeExpressionType;

import lombok.Data;

/**
 * @Author 刘文/Cliff Liu
 * @Date 2024/7/23
 */
@Data
public class JobInfo extends BaseDO {

    /* ************************** 任务基本信息 ************************** */
    /**
     * 任务名称
     */
    private String jobName;
    /**
     * 任务描述
     */
    private String jobDescription;

    /**
     * 任务所属的应用ID
     */
    private Long appId;

    /**
     * 任务自带的参数
     */
    private String jobParams;

    /* ************************** 定时参数 ************************** */
    /**
     * 时间表达式类型（CRON/API/FIX_RATE/FIX_DELAY）
     */
    private TimeExpressionType timeExpressionType;

    /**
     * 时间表达式，CRON/NULL/LONG/LONG
     */
    private String timeExpression;

    /* ************************** 执行方式 ************************** */
    /**
     * 执行类型，单机/广播/MR
     */
    private ExecuteType executeType;
    /**
     * 执行器类型，Java/Shell
     */
    private ProcessorType processorType;
    /**
     * 执行器信息
     */
    private String processorInfo;

    /* ************************** 运行时配置 ************************** */
    /**
     * 最大同时运行任务数，默认 1
     */
    private Integer maxInstanceNum;
    /**
     * 并发度，同时执行某个任务的最大线程数量
     */
    private Integer concurrency;
    /**
     * 任务整体超时时间
     */
    private Long instanceTimeLimit;

    /* ************************** 重试配置 ************************** */

    private Integer instanceRetryNum;

    private Integer taskRetryNum;

    /**
     * 状态
     */
    private StatusEnum status;
    /**
     * 下一次调度时间
     */
    private Long nextTriggerTime;
    /* ************************** 繁忙机器配置 ************************** */
    /**
     * 最低CPU核心数量，0代表不限
     */
    private double minCpuCores;
    /**
     * 最低内存空间，单位 GB，0代表不限
     */
    private double minMemorySpace;
    /**
     * 最低磁盘空间，单位 GB，0代表不限
     */
    private double minDiskSpace;
    /* ************************** 集群配置 ************************** */
    /**
     * 指定机器运行，空代表不限，非空则只会使用其中的机器运行（多值逗号分割）
     */
    private String designatedWorkers;
    /**
     * 最大机器数量
     */
    private Integer maxWorkerCount;
    /**
     * 报警用户ID列表，多值逗号分隔
     */
    private String notifyUserIds;

    /**
     * 派发策略
     */
    private DispatchStrategy dispatchStrategy;
    /**
     * 某种派发策略背后的具体配置，值取决于 dispatchStrategy
     */
    private String dispatchStrategyConfig;

    private String lifecycle;

    /**
     * 任务生命周期范围
     */
    @JsonSerialize(using = LongListSerializer.class)
    private List<Long> lifecycleRange;

    /**
     * 任务归类，开放给接入方自由定制
     */
    private String tag;

    /**
     * 日志配置，包括日志级别、日志方式等配置信息
     */
    private LogConfig logConfig;
}
